home *** CD-ROM | disk | FTP | other *** search
/ H4CK3R 14 / hacker14.iso / programacao / visual / perl.exe / {app} / Webroot / cgi-bin / save_state.cgi < prev    next >
Encoding:
Text File  |  2003-01-11  |  2.4 KB  |  68 lines

  1. #!perl
  2.  
  3. use CGI;
  4.  
  5. $query = new CGI;
  6.  
  7. print $query->header;
  8. print $query->start_html("Save and Restore Example");
  9. print "<H1>Save and Restore Example</H1>\n";
  10.  
  11. # Here's where we take action on the previous request
  12. &save_parameters($query)              if $query->param('action') eq 'SAVE';
  13. $query = &restore_parameters($query)  if $query->param('action') eq 'RESTORE';
  14.  
  15. # Here's where we create the form
  16. print $query->start_multipart_form;
  17. print "Popup 1: ",$query->popup_menu('popup1',[qw{red green purple magenta orange chartreuse brown}]),"\n";
  18. print "Popup 2: ",$query->popup_menu('popup2',[qw{lion tiger bear zebra potto wildebeest frog emu gazelle}]),"\n";
  19. print "<P>";
  20. $default_name = $query->remote_addr . '.sav';
  21. print "Save/restore state from file: ",$query->textfield('savefile',$default_name),"\n";
  22. print "<P>";
  23. print $query->submit('action','SAVE'),$query->submit('action','RESTORE');
  24. print "<P>",$query->defaults;
  25. print $query->endform;
  26.  
  27. # Here we print out a bit at the end
  28. print $query->end_html;
  29.  
  30. sub save_parameters {
  31.     local($query) = @_;
  32.     local($filename) = &clean_name($query->param('savefile'));
  33.     if (open(FILE,">$filename")) {
  34.         $query->save(FILE);
  35.         close FILE;
  36.         print "<STRONG>State has been saved to file $filename</STRONG>\n";
  37.         print "<P>If you remember this name you can restore the state later.\n";
  38.     } else {
  39.         print "<STRONG>Error:</STRONG> couldn't write to file $filename: $!\n";
  40.     }
  41. }
  42.  
  43. sub restore_parameters {
  44.     local($query) = @_;
  45.     local($filename) = &clean_name($query->param('savefile'));
  46.     if (open(FILE,$filename)) {
  47.         $query = new CGI(FILE);  # Throw out the old query, replace it with a new one
  48.         close FILE;
  49.         print "<STRONG>State has been restored from file $filename</STRONG>\n";
  50.     } else {
  51.         print "<STRONG>Error:</STRONG> couldn't restore file $filename: $!\n";
  52.     }
  53.     return $query;
  54. }
  55.  
  56.  
  57. # Very important subroutine -- get rid of all the naughty
  58. # metacharacters from the file name. If there are, we
  59. # complain bitterly and die.
  60. sub clean_name {
  61.    local($name) = @_;
  62.    unless ($name=~/^[\w\._\-]+$/) {
  63.       print "<STRONG>$name has naughty characters.  Only ";
  64.       print "alphanumerics are allowed.  You can't use absolute names.</STRONG>";
  65.       die "Attempt to use naughty characters";
  66.    }
  67.    return "$name";
  68. }